//两个整数之间的 汉明距离 指的是这两个数字对应二进制位不同的位置的数目。 
//
// 给你两个整数 x 和 y，计算并返回它们之间的汉明距离。 
//
// 
//
// 示例 1： 
//
// 
//输入：x = 1, y = 4
//输出：2
//解释：
//1   (0 0 0 1)
//4   (0 1 0 0)
//       ↑   ↑
//上面的箭头指出了对应二进制位不同的位置。
// 
//
// 示例 2： 
//
// 
//输入：x = 3, y = 1
//输出：1
// 
//
// 
//
// 提示： 
//
// 
// 0 <= x, y <= 2³¹ - 1 
// 
// Related Topics 位运算 👍 546 👎 0


package src.easy._0461.pck.s2;
public class HammingDistance {
    public static void main(String[] args) {
        Solution solution = new HammingDistance().new Solution();
        System.out.println("solution.hammingDistance(1,4) = " + solution.hammingDistance(1, 4));
    }
    //leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    /**
     * 手动实现的方式:logC
     * @param x
     * @param y
     * @return
     */
    public int hammingDistance(int x, int y) {
        int res = x ^ y;
        int count = 0;
        while(res != 0) {
            if((res & 1) == 1) {
                count++;
            }
            res = res >> 1;
        }
        return count;
    }
}
//leetcode submit region end(Prohibit modification and deletion)

}